home *** CD-ROM | disk | FTP | other *** search
/ Linux Cubed Series 3: Developer Tools / Linux Cubed Series 3 - Developer Tools.iso / devel / lang / lisp / guile-ii.src / guile-ii / guile-src / libguile / procs.c < prev    next >
Encoding:
C/C++ Source or Header  |  1995-06-15  |  3.6 KB  |  159 lines

  1. /*    Copyright (C) 1995 Free Software Foundation, Inc.
  2.  * 
  3.  * This program is free software; you can redistribute it and/or modify
  4.  * it under the terms of the GNU General Public License as published by
  5.  * the Free Software Foundation; either version 2, or (at your option)
  6.  * any later version.
  7.  * 
  8.  * This program is distributed in the hope that it will be useful,
  9.  * but WITHOUT ANY WARRANTY; without even the implied warranty of
  10.  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  11.  * GNU General Public License for more details.
  12.  * 
  13.  * You should have received a copy of the GNU General Public License
  14.  * along with this software; see the file COPYING.  If not, write to
  15.  * the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
  16.  *
  17.  * As a special exception, the Free Software Foundation gives permission
  18.  * for additional uses of the text contained in its release of GUILE.
  19.  *
  20.  * The exception is that, if you link the GUILE library with other files
  21.  * to produce an executable, this does not by itself cause the
  22.  * resulting executable to be covered by the GNU General Public License.
  23.  * Your use of that executable is in no way restricted on account of
  24.  * linking the GUILE library code into it.
  25.  *
  26.  * This exception does not however invalidate any other reasons why
  27.  * the executable file might be covered by the GNU General Public License.
  28.  *
  29.  * This exception applies only to the code released by the
  30.  * Free Software Foundation under the name GUILE.  If you copy
  31.  * code from other Free Software Foundation releases into a copy of
  32.  * GUILE, as the General Public License permits, the exception does
  33.  * not apply to the code that you add in this way.  To avoid misleading
  34.  * anyone as to the status of such modified files, you must delete
  35.  * this exception notice from them.
  36.  *
  37.  * If you write modifications of your own for GUILE, it is your choice
  38.  * whether to permit this exception to apply to your modifications.
  39.  * If you do not wish that, delete this exception notice.  
  40.  */
  41.  
  42.  
  43. #include <stdio.h>
  44. #include "_scm.h"
  45.  
  46.  
  47.  
  48.  
  49.  
  50. /* {Procedures}
  51.  */
  52.  
  53. #ifdef __STDC__
  54. SCM 
  55. scm_make_subr (char *name, int type, SCM (*fcn) ())
  56. #else
  57. SCM 
  58. scm_make_subr (name, type, fcn)
  59.      char *name;
  60.      int type;
  61.      SCM (*fcn) ();
  62. #endif
  63. {
  64.   SCM symcell = scm_sysintern (name, SCM_UNDEFINED);
  65.   long tmp = ((((CELLPTR) (CAR (symcell))) - scm_heap_org) << 8);
  66.   register SCM z;
  67.   if ((tmp >> 8) != ((CELLPTR) (CAR (symcell)) - scm_heap_org))
  68.     tmp = 0;
  69.   NEWCELL (z);
  70.   SUBRF (z) = fcn;
  71.   CAR (z) = tmp + type;
  72.   CDR (symcell) = z;
  73.   return z;
  74. }
  75.  
  76. #ifdef CCLO
  77. #ifdef __STDC__
  78. SCM 
  79. scm_makcclo (SCM proc, long len)
  80. #else
  81. SCM 
  82. scm_makcclo (proc, len)
  83.      SCM proc;
  84.      long len;
  85. #endif
  86. {
  87.   SCM s;
  88.   NEWCELL (s);
  89.   DEFER_INTS;
  90.   SETCHARS (s, scm_must_malloc (len * sizeof (SCM), "compiled-closure"));
  91.   SETLENGTH (s, len, tc7_cclo);
  92.   while (--len)
  93.     VELTS (s)[len] = UNSPECIFIED;
  94.   CCLO_SUBR (s) = proc;
  95.   ALLOW_INTS;
  96.   return s;
  97. }
  98. #endif
  99.  
  100.  
  101.  
  102. PROC (s_procedure_p, "procedure?", 1, 0, 0, scm_procedure_p);
  103. #ifdef __STDC__
  104. SCM 
  105. scm_procedure_p (SCM obj)
  106. #else
  107. SCM 
  108. scm_procedure_p (obj)
  109.      SCM obj;
  110. #endif
  111. {
  112.   if (NIMP (obj))
  113.     switch (TYP7 (obj))
  114.       {
  115.       case tcs_closures:
  116.       case tc7_contin:
  117.       case tcs_subrs:
  118. #ifdef CCLO
  119.       case tc7_cclo:
  120. #endif
  121.     return BOOL_T;
  122.       default:
  123.     return BOOL_F;
  124.       }
  125.   return BOOL_F;
  126. }
  127.  
  128.  
  129. #ifdef __STDC__
  130. void
  131. scm_init_iprocs(scm_iproc *subra, int type)
  132. #else
  133. void
  134. scm_init_iprocs(subra, type)
  135.      scm_iproc *subra;
  136.      int type;
  137. #endif
  138. {
  139.   for(;subra->scm_string; subra++)
  140.     scm_make_subr(subra->scm_string,
  141.           type,
  142.           subra->cproc);
  143. }
  144.  
  145.  
  146.  
  147.  
  148. #ifdef __STDC__
  149. void
  150. scm_init_procs (void)
  151. #else
  152. void
  153. scm_init_procs ()
  154. #endif
  155. {
  156. #include "procs.x"
  157. }
  158.  
  159.